# Projekt UART

Jméno: Aleksandr Shevchenko Login: xshevc01

### 1 RTL

#### 1.1 Schéma obvodu



### 1.2 Popis

Počítadlo CNT (CLK) počítá hodinové signály následovně: je ve stavu RST, když není nastaven CNT\_CLK\_EN anebo když máme poslední načtený bit.

Počítadlo CNT (BITS) počítá bity následovně: na vstupu má 1, pokud zároveň máme nastaveno RECEIVE\_EN a když minulo 16 hodinových signálů.

Dál pomocí decóderu DC 3-8 uchováváme do registrů REG 1-REG 8 bity ze vstupu.

## 2 Návrh automatu (Finite State Machine)

#### 2.1 Schéma automatu



### 2.2 Legenda

- Stavy automatu: WAIT\_START, WAIT\_LSB, RECEIVE\_BITS, WAIT\_STOP, VALIDATION.
- Vstupní signály: DIN, CNT\_CLK, CNT\_BITS.
- Moorovy výstupy (v tomto pořádí jsou vypsané v FSM): CNT\_CLK\_EN, RECEIVE\_EN, DATA\_VLD.

### 2.3 Popis

- WAIT\_START: čekáme na nastavení START bitu na 0.
- WAIT\_LSB: začátek přenosu počítáme 1,5 period (celkem 24 signálů) CLK, abychom dosáhli "středu" LSB.
- RECEIVE\_BITS: uchováváme do registrů vstupní bity, dokud neni je 8.
- WAIT\_STOP: data jsou uložena, čekáme na nastavení STOP bitu na 1.
- VALIDATION: provádí se validace nastavení DOUT\_VLD na 1. Konec cyklu, přechod do stavu WAIT\_START.

# 3 Snímek obrazovky ze simulací

